昨天为了测试HTTP POST上传文件,在Mac本地使用Apache快速搭建了一个文件上传服务器。Mac自带Apache和PHP,所以只需要做一些配置就行了。
1. 配置Apache
启动Apache
sudo apachectl -k start
查看版本
httpd -v
进入apache目录
cd /etc/apache2/
备份配置文件
sudo cp httpd.conf httpd.conf.bak
新建一个Sites文件夹用于存放网站文件
mkdir ~/Sites
编辑httpd.conf
sudo nano httpd.conf
注释掉默认的网站目录
DocumentRoot "/Library/WebServer/Documents"
前面加上#
改为
DocumentRoot "/Users/用户名/Sites"
(替换用户名
改为你的实际路径)
添加下面的内容:
<Directory "/Users/用户名/Sites">
Options FollowSymLinks Multiviews
MultiviewsMatch Any
AllowOverride All
Require all granted
</Directory>
然后在~/Sites
文件夹下添加一个index.html
文件,内容为
<html>
<head>
<title>测试</title>
</head>
<body>
<h1>Hello World!</h1>
</body>
</html>
重新启动Apache
sudo apachectl -k restart
访问 127.0.0.1
或者localhost
看到Hello World!
表示搭建成功
2. 配置php
编辑httpd.conf
,取消下面一行的注释符号#:
LoadModule php7_module libexec/apache2/libphp7.so
复制php.ini
sudo cp /etc/php.ini.default /etc/php.ini
重新启动Apache
sudo apachectl -k restart
在~/Sites
文件夹添加一个index.php
文件,内容如下:
<html>
<head>
<title>测试</title>
</head>
<body>
<h1>Hello World!</h1>
<?php phpinfo(); ?>
</body>
</html>
访问 127.0.0.1/index.php
看到如下内容表示成功:
3. 文件上传测试
创建一个上传文件夹并修改权限:
mkdir ~/Sites/upload
chmod 777 ~/Sites/upload
在~/Sites
文件夹创建两文件夹 upload.html
和upload_file.php
(参考了PHP 文件上传 | 菜鸟教程)。
upload.html
内容如下:
<html>
<head>
<meta charset="utf-8">
<title>Upload Form</title>
</head>
<body>
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<label for="file">文件名:</label>
<input type="file" name="file" id="file"><br>
<input type="submit" name="submit" value="提交">
</form>
</body>
</html>
upload_file.php内容如下(限制了文件上传扩展名为gif/jpeg/jpg/png,大小限制为2M):
<?php
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
echo $_FILES["file"]["size"];
$extension = end($temp); // 获取文件后缀名
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 2048000) // 小于 2M
&& in_array($extension, $allowedExts))
{
if ($_FILES["file"]["error"] > 0)
{
echo "错误:: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>";
// 判断当期目录下的 upload 目录是否存在该文件
// 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
if (file_exists("upload/" . $_FILES["file"]["name"]))
{
echo $_FILES["file"]["name"] . " 文件已经存在。 ";
}
else
{
// 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
echo "文件存储在: " . "upload/" . $_FILES["file"]["name"];
}
}
}
else
{
echo "非法的文件格式";
}
?>
访问http://127.0.0.1/upload.html
表单可以上传文件。
或者使用下面的curl命令:
curl -F "file=@/Users/username/Pictures/nice.jpg" "http://localhost/upload_file.php" -v
4. 停止Apache
sudo apachectl stop
5. POSTMAN模拟HTTP POST上传
按照图中设置即可,查看代码可以点击右侧的Code
6. 需要解决的问题
尝试不使用php而直接使用curl
进行POST
或者PUT
会遇到301错误。